home *** CD-ROM | disk | FTP | other *** search
/ MACD 5 / MACD 5.bin / workbench / blankery / blanker / source / blankers / clock / clock.c < prev    next >
C/C++ Source or Header  |  1993-07-03  |  7KB  |  271 lines

  1. /*
  2.  *  Source machine generated by GadToolsBox V2.0b
  3.  *  which is (c) Copyright 1991-1993 Jaba Development
  4.  *
  5.  *  GUI Designed by : Michael D. Bayne
  6.  */
  7.  
  8. #include <exec/types.h>
  9. #include <intuition/intuition.h>
  10. #include <intuition/classes.h>
  11. #include <intuition/classusr.h>
  12. #include <intuition/imageclass.h>
  13. #include <intuition/gadgetclass.h>
  14. #include <libraries/gadtools.h>
  15. #include <graphics/displayinfo.h>
  16. #include <graphics/gfxbase.h>
  17. #include <clib/exec_protos.h>
  18. #include <clib/intuition_protos.h>
  19. #include <clib/gadtools_protos.h>
  20. #include <clib/graphics_protos.h>
  21. #include <clib/utility_protos.h>
  22. #include <string.h>
  23. #include <clib/diskfont_protos.h>
  24.  
  25. #include "Clock.h"
  26.  
  27. struct Screen         *Scr = NULL;
  28. UBYTE                 *PubScreenName = "Workbench";
  29. APTR                   VisualInfo = NULL;
  30. struct Window         *ClockWnd = NULL;
  31. struct Gadget         *ClockGList = NULL;
  32. struct IntuiMessage    ClockMsg;
  33. struct Gadget         *ClockGadgets[10];
  34. UWORD                  ClockLeft = 0;
  35. UWORD                  ClockTop = 12;
  36. UWORD                  ClockWidth = 307;
  37. UWORD                  ClockHeight = 59;
  38. UBYTE                 *ClockWdt = (UBYTE *)"Clock Prefs";
  39. struct TextAttr       *Font, Attr;
  40. UWORD                  FontX, FontY;
  41. UWORD                  OffX, OffY;
  42. struct TextFont       *ClockFont = NULL;
  43.  
  44. UBYTE *MIL0Labels[] = {
  45.     (UBYTE *)"12 Hour",
  46.     (UBYTE *)"24 Hour",
  47.     NULL };
  48.  
  49. UBYTE *SECS0Labels[] = {
  50.     (UBYTE *)"Hr:Mn",
  51.     (UBYTE *)"Hr:Mn:Sc",
  52.     NULL };
  53.  
  54. UBYTE *CYCLE0Labels[] = {
  55.     (UBYTE *)"Cycle",
  56.     (UBYTE *)"Random",
  57.     (UBYTE *)"White",
  58.     (UBYTE *)"Copper",
  59.     NULL };
  60.  
  61. UWORD ClockGTypes[] = {
  62.     BUTTON_KIND,
  63.     TEXT_KIND,
  64.     BUTTON_KIND,
  65.     BUTTON_KIND,
  66.     NUMBER_KIND,
  67.     SLIDER_KIND,
  68.     CYCLE_KIND,
  69.     CYCLE_KIND,
  70.     CYCLE_KIND,
  71.     BUTTON_KIND
  72. };
  73.  
  74. struct NewGadget ClockNGad[] = {
  75.     5, 18, 58, 13, (UBYTE *)"_Font...", NULL, GD_FONT, PLACETEXT_IN, NULL, (APTR)FONTClicked,
  76.     67, 18, 195, 13, NULL, NULL, GD_FTXT, 0, NULL, NULL,
  77.     5, 44, 82, 13, (UBYTE *)"_Ok", NULL, GD_OK, PLACETEXT_IN, NULL, (APTR)OKClicked,
  78.     221, 44, 82, 13, (UBYTE *)"_Cancel", NULL, GD_CANCEL, PLACETEXT_IN, NULL, (APTR)CANCELClicked,
  79.     266, 18, 37, 13, NULL, NULL, GD_FSIZE, 0, NULL, NULL,
  80.     67, 33, 195, 9, (UBYTE *)"_Speed", NULL, GD_SPEED, PLACETEXT_LEFT, NULL, (APTR)SPEEDClicked,
  81.     5, 2, 82, 13, NULL, NULL, GD_MIL, 0, NULL, (APTR)MILClicked,
  82.     113, 2, 82, 13, NULL, NULL, GD_SECS, 0, NULL, (APTR)SECSClicked,
  83.     221, 2, 82, 13, NULL, NULL, GD_CYCLE, 0, NULL, (APTR)CYCLEClicked,
  84.     113, 44, 82, 13, (UBYTE *)"_Test", NULL, GD_TEST, PLACETEXT_IN, NULL, (APTR)TESTClicked
  85. };
  86.  
  87. ULONG ClockGTags[] = {
  88.     (GT_Underscore), '_', (TAG_DONE),
  89.     (GTTX_Border), TRUE, (TAG_DONE),
  90.     (GT_Underscore), '_', (TAG_DONE),
  91.     (GT_Underscore), '_', (TAG_DONE),
  92.     (GTNM_Border), TRUE, (TAG_DONE),
  93.     (GTSL_Min), 1, (GTSL_Max), 50, (GTSL_Level), 10, (GTSL_MaxLevelLen), 4, (GTSL_LevelFormat), (ULONG)"%3ld", (GTSL_LevelPlace), (PLACETEXT_RIGHT), (PGA_Freedom), LORIENT_HORIZ, (GA_RelVerify), TRUE, (GT_Underscore), '_', (TAG_DONE),
  94.     (GTCY_Labels), (ULONG)&MIL0Labels[ 0 ], (TAG_DONE),
  95.     (GTCY_Labels), (ULONG)&SECS0Labels[ 0 ], (GTCY_Active), 1, (TAG_DONE),
  96.     (GTCY_Labels), (ULONG)&CYCLE0Labels[ 0 ], (TAG_DONE),
  97.     (GT_Underscore), '_', (TAG_DONE)
  98. };
  99.  
  100. static UWORD ComputeX( UWORD value )
  101. {
  102.     return(( UWORD )((( FontX * value ) + 3 ) / 6 ));
  103. }
  104.  
  105. static UWORD ComputeY( UWORD value )
  106. {
  107.     return(( UWORD )((( FontY * value ) + 4 ) / 8 ));
  108. }
  109.  
  110. static void ComputeFont( UWORD width, UWORD height )
  111. {
  112.     Forbid();
  113.     Font = &Attr;
  114.     Font->ta_Name = (STRPTR)GfxBase->DefaultFont->tf_Message.mn_Node.ln_Name;
  115.     Font->ta_YSize = FontY = GfxBase->DefaultFont->tf_YSize;
  116.     FontX = GfxBase->DefaultFont->tf_XSize;
  117.     Permit();
  118.  
  119.     OffX = Scr->WBorLeft;
  120.     OffY = Scr->RastPort.TxHeight + Scr->WBorTop + 1;
  121.  
  122.     if ( width && height ) {
  123.         if (( ComputeX( width ) + OffX + Scr->WBorRight ) > Scr->Width )
  124.             goto UseTopaz;
  125.         if (( ComputeY( height ) + OffY + Scr->WBorBottom ) > Scr->Height )
  126.             goto UseTopaz;
  127.     }
  128.     return;
  129.  
  130. UseTopaz:
  131.     Font->ta_Name = (STRPTR)"topaz.font";
  132.     FontX = FontY = Font->ta_YSize = 8;
  133. }
  134.  
  135. int SetupScreen( void )
  136. {
  137.     if ( ! ( Scr = LockPubScreen( PubScreenName )))
  138.         return( 1L );
  139.  
  140.     ComputeFont( 0, 0 );
  141.  
  142.     if ( ! ( VisualInfo = GetVisualInfo( Scr, TAG_DONE )))
  143.         return( 2L );
  144.  
  145.     return( 0L );
  146. }
  147.  
  148. void CloseDownScreen( void )
  149. {
  150.     if ( VisualInfo ) {
  151.         FreeVisualInfo( VisualInfo );
  152.         VisualInfo = NULL;
  153.     }
  154.  
  155.     if ( Scr        ) {
  156.         UnlockPubScreen( NULL, Scr );
  157.         Scr = NULL;
  158.     }
  159. }
  160.  
  161. int HandleClockIDCMP( void )
  162. {
  163.     struct IntuiMessage    *m;
  164.     int            (*func)();
  165.     BOOL            running = TRUE;
  166.  
  167.     while( m = GT_GetIMsg( ClockWnd->UserPort )) {
  168.  
  169.         CopyMem(( char * )m, ( char * )&ClockMsg, (long)sizeof( struct IntuiMessage ));
  170.  
  171.         GT_ReplyIMsg( m );
  172.  
  173.         switch ( ClockMsg.Class ) {
  174.  
  175.             case    IDCMP_REFRESHWINDOW:
  176.                 GT_BeginRefresh( ClockWnd );
  177.                 GT_EndRefresh( ClockWnd, TRUE );
  178.                 break;
  179.  
  180.             case    IDCMP_VANILLAKEY:
  181.                 running = ClockVanillaKey();
  182.                 break;
  183.  
  184.             case    IDCMP_GADGETUP:
  185.             case    IDCMP_GADGETDOWN:
  186.                 func = ( void * )(( struct Gadget * )ClockMsg.IAddress )->UserData;
  187.                 running = func();
  188.                 break;
  189.         }
  190.     }
  191.     return( running );
  192. }
  193.  
  194. int OpenClockWindow( void )
  195. {
  196.     struct NewGadget    ng;
  197.     struct Gadget    *g;
  198.     UWORD        lc, tc;
  199.     UWORD        wleft = ClockLeft, wtop = ClockTop, ww, wh;
  200.  
  201.     ComputeFont( ClockWidth, ClockHeight );
  202.  
  203.     ww = ComputeX( ClockWidth );
  204.     wh = ComputeY( ClockHeight );
  205.  
  206.     wleft = ( Scr->Width - ww )/2 - Scr->WBorRight;
  207.     wtop = ( Scr->Height - wh - Font->ta_YSize )/2 - Scr->WBorBottom;
  208.  
  209.     if ( ! ( ClockFont = OpenDiskFont( Font )))
  210.         return( 5L );
  211.  
  212.     if ( ! ( g = CreateContext( &ClockGList )))
  213.         return( 1L );
  214.  
  215.     for( lc = 0, tc = 0; lc < Clock_CNT; lc++ ) {
  216.  
  217.         CopyMem((char * )&ClockNGad[ lc ], (char * )&ng, (long)sizeof( struct NewGadget ));
  218.  
  219.         ng.ng_VisualInfo = VisualInfo;
  220.         ng.ng_TextAttr   = Font;
  221.         ng.ng_LeftEdge   = OffX + ComputeX( ng.ng_LeftEdge );
  222.         ng.ng_TopEdge    = OffY + ComputeY( ng.ng_TopEdge );
  223.         ng.ng_Width      = ComputeX( ng.ng_Width );
  224.         ng.ng_Height     = ComputeY( ng.ng_Height);
  225.  
  226.         ClockGadgets[ lc ] = g = CreateGadgetA((ULONG)ClockGTypes[ lc ], g, &ng, ( struct TagItem * )&ClockGTags[ tc ] );
  227.  
  228.         while( ClockGTags[ tc ] ) tc += 2;
  229.         tc++;
  230.  
  231.         if ( NOT g )
  232.             return( 2L );
  233.     }
  234.  
  235.     if ( ! ( ClockWnd = OpenWindowTags( NULL,
  236.                 WA_Left,    wleft,
  237.                 WA_Top,        wtop,
  238.                 WA_Width,    ww + OffX + Scr->WBorRight,
  239.                 WA_Height,    wh + OffY + Scr->WBorBottom,
  240.                 WA_IDCMP,    BUTTONIDCMP|TEXTIDCMP|NUMBERIDCMP|SLIDERIDCMP|CYCLEIDCMP|IDCMP_VANILLAKEY|IDCMP_REFRESHWINDOW,
  241.                 WA_Flags,    WFLG_DRAGBAR|WFLG_DEPTHGADGET|WFLG_SMART_REFRESH|WFLG_ACTIVATE|WFLG_RMBTRAP,
  242.                 WA_Gadgets,    ClockGList,
  243.                 WA_Title,    ClockWdt,
  244.                 WA_ScreenTitle,    "Clock Prefs",
  245.                 TAG_DONE )))
  246.     return( 4L );
  247.  
  248.     GT_RefreshWindow( ClockWnd, NULL );
  249.  
  250.     return( 0L );
  251. }
  252.  
  253. void CloseClockWindow( void )
  254. {
  255.     if ( ClockWnd        ) {
  256.         CloseWindow( ClockWnd );
  257.         ClockWnd = NULL;
  258.     }
  259.  
  260.     if ( ClockGList      ) {
  261.         FreeGadgets( ClockGList );
  262.         ClockGList = NULL;
  263.     }
  264.  
  265.     if ( ClockFont ) {
  266.         CloseFont( ClockFont );
  267.         ClockFont = NULL;
  268.     }
  269. }
  270.  
  271.